<?php 
ini_set('date.timezone','Asia/Shanghai');
header("Content-Type:text/html;charset=utf-8");
//error_reporting(E_ERROR);
require_once "../lib/WxPay.Api.php";
require_once "WxPay.JsApiPay.php";
require_once 'log.php';

//初始化日志
$logHandler= new CLogFileHandler("../logs/".date('Y-m-d').'.log');
$log = Log::Init($logHandler, 15);

//打印输出数组信息
function printf_info($data)
{
    foreach($data as $key=>$value){
        echo "<font color='#00ff55;'>$key</font> : $value <br/>";
    }
}
//①、获取用户openid
$tools = new JsApiPay();
//$openId = $tools->GetOpenid();


if(empty($_POST['openId'])){
	echo "<script>alert('openId不能为空');history.go(-1);</script>";
	exit();
}


$openId = $_POST['openId'];
$total_fee = $_POST['total_fee'];
$subject = $_POST['subject'];
$orderid = $_POST['orderid'];
$date = $_POST['date'];
$backUrl = 'http://' . $_SERVER['HTTP_HOST'] . '/oc3/WeCatPayCallBack.php';
$headerUrl = 'http://' . $_SERVER['HTTP_HOST'] . '/phone/hotelOrder';


$time1 = strtotime(date("Y-m-d H:i:s"));
$time2 = strtotime($date)+7200;
if($time1>$time2){
	echo "<script>alert('已超时,请重新下单');history.go(-1);</script>";
	exit();
}


//②、统一下单
$input = new WxPayUnifiedOrder();
$input->SetBody($subject);
$input->SetAttach($subject);
$input->SetOut_trade_no($orderid);
$input->SetTotal_fee($total_fee*100);
//$input->SetTotal_fee("1");
$input->SetTime_start(date("YmdHis"));
$input->SetTime_expire(date("YmdHis", time() + 7200));
$input->SetGoods_tag("");
$input->SetNotify_url($backUrl);
$input->SetTrade_type("JSAPI");
$input->SetOpenid($openId);
$order = WxPayApi::unifiedOrder($input);
//echo '<font color="#f00"><b>统一下单支付单信息</b></font><br/>';
//printf_info($order);exit();
$jsApiParameters = $tools->GetJsApiParameters($order);

//获取共享收货地址js函数参数
$editAddress = $tools->GetEditAddressParameters();

//③、在支持成功回调通知中处理成功之后的事宜，见 notify.php
/**
 * 注意：
 * 1、当你的回调地址不可访问的时候，回调通知会失败，可以通过查询订单来确认支付是否成功
 * 2、jsapi支付时需要填入用户openid，WxPay.JsApiPay.php中有获取openid流程 （文档可以参考微信公众平台“网页授权接口”，
 * 参考http://mp.weixin.qq.com/wiki/17/c0f37d5704f0b64713d5d2c37b468d75.html）
 */
?>
<!DOCTYPE HTML>
<html>
<head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1"/> 
	<link rel="stylesheet" href="/theme/simple/assets/css/weui.css">
    <title>支付</title>
    <script type="text/javascript">
	//调用微信JS api 支付
	function jsApiCall()
	{
		WeixinJSBridge.invoke(
			'getBrandWCPayRequest',
			<?php echo $jsApiParameters; ?>,
			function(res){
				WeixinJSBridge.log(res.err_msg);
				//alert(res.err_code+res.err_desc+res.err_msg);
				 if(res.err_msg == "get_brand_wcpay_request:ok"){    
                    alert("支付成功!");  
					var headerUrl = "<?php echo $headerUrl;?>";
                    window.location.href = headerUrl;
                }else if(res.err_msg == "get_brand_wcpay_request:cancel"){    
                    alert("用户取消支付!");    
                }else{    
                    alert("支付失败!");    
                }    
			}
		);
	}

	function callpay()
	{
		if (typeof WeixinJSBridge == "undefined"){
		    if( document.addEventListener ){
		        document.addEventListener('WeixinJSBridgeReady', jsApiCall, false);
		    }else if (document.attachEvent){
		        document.attachEvent('WeixinJSBridgeReady', jsApiCall); 
		        document.attachEvent('onWeixinJSBridgeReady', jsApiCall);
		    }
		}else{
		    jsApiCall();
		}
	}
	</script>
	<script type="text/javascript">
	//获取共享地址
	function editAddress()
	{
		WeixinJSBridge.invoke(
			'editAddress',
			<?php echo $editAddress; ?>,
			function(res){
				var value1 = res.proviceFirstStageName;
				var value2 = res.addressCitySecondStageName;
				var value3 = res.addressCountiesThirdStageName;
				var value4 = res.addressDetailInfo;
				var tel = res.telNumber;
				
				//alert(value1 + value2 + value3 + value4 + ":" + tel);
			}
		);
	}
	
	window.onload = function(){
		if (typeof WeixinJSBridge == "undefined"){
		    if( document.addEventListener ){
		        document.addEventListener('WeixinJSBridgeReady', editAddress, false);
		    }else if (document.attachEvent){
		        document.attachEvent('WeixinJSBridgeReady', editAddress); 
		        document.attachEvent('onWeixinJSBridgeReady', editAddress);
		    }
		}else{
			editAddress();
		}
	};
	
	</script>
</head>
<body>
	<div class="container" id="container">
		<div class="page__hd" style="margin-top:30px;padding:10px 10px;">
			<h3 class="page__title">支付</h3>
		</div>
	
		<div class="page__bd">
			<div class="weui-form-preview">
				<div class="weui-form-preview__hd">
					<div class="weui-form-preview__item">
						<label class="weui-form-preview__label">付款金额</label>
						<em class="weui-form-preview__value">¥<?php echo $total_fee;?></em>
					</div>
				</div>
				<div class="weui-form-preview__bd">
					<div class="weui-form-preview__item">
						<label class="weui-form-preview__label">订单号</label>
						<span class="weui-form-preview__value"><?php echo $orderid;?></span>
					</div>
					<div class="weui-form-preview__item">
						<label class="weui-form-preview__label">详情</label>
						<span class="weui-form-preview__value"><?php echo $subject;?></span>
					</div>
					<div class="weui-form-preview__item">
						<label class="weui-form-preview__label"></label>
						<span class="weui-form-preview__value"></span>
					</div>
				</div>

			</div>
			
			
			<div class="weui-btn-area">
			  <a class="weui-btn weui-btn_primary" href="javascript:" id="showTooltips" onclick="callpay()">立即支付</a>
			</div>
			
		</div>

	</div>
	<!--
    <br/>
    <font color="#9ACD32"><b>该笔订单支付金额为<span style="color:#f00;font-size:50px">1分</span>钱</b></font><br/><br/>
	<div align="center">
		<button style="width:210px; height:50px; border-radius: 15px;background-color:#FE6714; border:0px #FE6714 solid; cursor: pointer;  color:white;  font-size:16px;" type="button" onclick="callpay()" >立即支付</button>
	</div>
	-->
</body>
</html>